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DETAILED ACTION 

1 . This application has been examined. 

2. Claims 1-28 have been examined and rejected. 

Claim Interpretation 

3. Claim 4 is directed to: the generated code consisting of instructions to load the code libraries. 
This claim was interpreted as being directed to loading the machine control instructions contained in the 
libraries that are represented by the objects in the graphical representation of the system when the 
machine code is generated. 

4. Claim 17 is directed to: the step of monitoring or tracing the path of data flow and execution of 
the generated code by visually indicating activity in active objects in the network, however the meaning 
of this claim is unclear. This claim was interpreted as being directed to the ability to monitor the creation 
of the machine code as the code is created for each object in the system which would visually indicate 
activity of active objects in the system, those "active objects" being those objects whose source code is 
being generated. 

Claim Rejections - 35 USC § 102 

5. The following is a quotation of the appropriate paragraphs of 35 U.S.C. 102 that form the basis 
for the rejections under this section made in this Office action: 

A person shall be entitled to a patent unless - 

(b) the invention was patented or described in a printed publication in this or a foreign country or 
in public use or on sale in this country, more than one year prior to the date of application for 
patent in the United States. 

6. Claims 1-7, 10,11, 14-17, 20-24, 26 and 17 are rejected under 35 U.S.C. 102(b) as being 
anticipated by Marmelstein (U.S. Patent Number 5,187,788), herein referred to as Marmelstein. 

7. As to Claim 1, Marmelstein teaches: a method executed by a mechanical, electronic or computer 
system for generating machine control instructions, the method comprising the steps of: reading in a user 
input to select an object from a library of objects, wherein the objects consist of sets of machine control 
instructions for performing one or more functions (column 10, lines 12-18 and column 17, lines 52-55); 
connecting the selected object to a network of objects consisting of those objects previously selected and 
connected by the user, including identifying the inputs and outputs of the selected object and connecting 
these inputs and outputs to the inputs and outputs of the other objects in the network (column 17, lines 
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55-58 and column 19, lines 24-32); generating machine control instructions using the instructions 
contained in the network of objects (column 18, lines 53-55); updating the network of objects and the 
connections in the network to accurately reflect any changes made to the generated machine control 
instructions or to the network of objects (column 33, lines 28-34, 40-47). 

8. As to Claim 2, M armelstein teaches: generating machine control instructions (column 18, lines 
53-55) and updating the network of objects and the connections in the network to accurately reflect any 
changes made to the generated machine control instructions or to the network of objects (column 33, 
lines 28-34, 40-47). It is concluded from the description in the specification that the user would only 
select the "Generate Ada" (Figure 5, element 513) option when they have completed constructing or 
modifying the network since the "Generate Ada" command produces source code for a completed APEX 
representation of the system. 

9. As to Claim 3, Marmelstein teaches: the functions contained in the objects are used to generate 
the corresponding sets of instructions for inclusion in the generated machine control instructions (column 
3, lines 19-20) whereby the direct mappings generate the corresponding set of Ada instructions. 

10. As to Claim 4, Marmelstein teaches: the generated code consists of computer instructions to 
load the code libraries represented by the objects (column 10, lines 15-18, column 18, lines 53-57) 
wherein the objects selected point to code containing machine control instructions in a database, or 
library, and this code is read in and compiled when the Ada code is generated. 

11. As to Claims 5 and 23, Marmelstein teaches: the user is a computer program (column 2, lines 
58-59) wherein APEX is the computer program. 

12. As to Claim 6, Marmelstein teaches: the machine control instructions are computer instructions 
belonging to an instruction set architecture (column 7, lines 13-19), wherein the APEX program is run on 
a Sun 3/XXX Workstation, therefore, the Ada instructions generated by this program belong to the 
instruction set architecture utilized by this system. 

13. As to Claim 7, Marmelstein teaches: wherein the machine control instructions consist of source 
code in a computer programming or scripting language (column 2, lines 58-59). 

14. As to Claim 10, Marmelstein teaches: the library of objects includes container objects that 
contain other objects or data (column 17, lines 52-55) wherein the objects (packages) contain data 
structures and the operations of these data structures. 

15. As to Claim 11, Marmelstein teaches: the user input is generated by the manipulation of 
graphical depictions of objects on a computer or video display screen or monitor, said manipulation being 
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controlled by a computer mouse or a keyboard or some combination of a computer mouse and keyboard 
(column 18, lines 8-14). 

16. As to Claim 14, Marmelstein teaches: the user input consists of the movement and connection of 
physical objects in physical space corresponding to objects in the library (column 18, lines 31-32) 
wherein the object can be positioned on the screen, (column 19, lines 24-32) wherein the connection of 
physical objects are made, (column 17, lines 52-55) wherein packages contain data structures and 
operations on the data structures read in from the library (column 17, lines 61-63). 

17. As to Claim 15, Marmelstein teaches: the step of removing any number of objects from the 
network in response to user inputs (column 33, lines 28-34). 

18. As to Claims 16 and 26, Marmelstein teaches: the step of modifying existing connections of 
objects in the network in response to user inputs (column 19, lines 35-37). 

19. As to Claims 17 and 27, Marmelstein teaches: the step of monitoring or tracing the path of data 
flow and execution of the generated code by visually indicating activity in active objects in the network 
(column 18, lines 55-57) wherein all generated code is sent to the console screen for monitoring by the 
user. 

20. As to Claim 20, Marmelstein teaches: the step of creating at least one new object of machine 
control instructions from the generated code (column 6, line 66-column 7, line 4). 

21 . As to Claim 21, Marmelstein teaches: a method for constructing a high-level object model from 
generated machine control instructions, the method comprising the steps of: reading in a sequence of 
machine control instructions for performing one or more functions (Figure 13, element 1310 and 
description); searching a library of objects for one or more objects that generate the sequence of machine 
control instructions read (Figure 13, elements 1320-1370 and description); parsing each matched 
sequence of machine control instructions to determine the objects connected to the inputs and outputs of 
each matching object found in the library of objects (column 11, lines 48-63) wherein the inputs and 
outputs of connecting objects of the matching object found in the library; connecting each matched 
object found in the library of objects to the other objects in the high-level model found in the previous 
steps (column 19, lines 24-32). 

22. As to Claim 22, Marmelstein teaches: the original machine control instructions were generated 
from a source file by a compiler (column 18, lines 53-57) since the machine control instructions (Ada 
source code) was generated from a source file (APEX system representation). 

23. As to Claim 24, Marmelstein teaches: the additional final step of generating machine control 
instructions from the high-level model (column 18, lines 53-55). 
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Claim Rejections - 35 USC § 103 

24. The following is a quotation of 35 U.S.C. 103(a) which forms the basis for all obviousness 
rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as 
set forth in section 102 of this title, if the differences between the subject matter sought to be 
patented and the prior art are such that the subject matter as a whole would have been obvious at 
the time the invention was made to a person having ordinary skill in the art to which said subject 
matter pertains. Patentability shall not be negatived by the manner in which the invention was 
made. 

25. The factual inquiries set forth in Graham v. John Deere Co., 383 U.S. 1, 148 USPQ 459 (1966), 
that are applied for establishing a background for determining obviousness under 35 U.S.C. 103(a) are 
summarized as follows: 

1 . Determining the scope and contents of the prior art. 

2. Ascertaining the differences between the prior art and the claims at issue. 

3. Resolving the level of ordinary skill in the pertinent art. 

4. Considering objective evidence present in the application indicating obviousness or 
nonobviousness. 

26. Claims 8 and 25 are rejected under 35 U.S.C. 103(a) as being unpatentable over Marmelstein as 
applied to Claims 1 and 21 above, and further in view of Brender et al (U.S. Patent Number 5,339,422), 
herein referred to as Brender. 

27. As to Claims 8 and 25, Marmelstein teaches compiling machine control instructions. 

28. Marmelstein does not expressly teach the additional final step of translating or compiling the 
machine control instructions into another format of machine control instructions, wherein the format of 
the newly generated machine control instructions differs from that of the original machine control 
instructions 

29. Brender teaches translating or compiling the machine control instructions into another format of 
machine control instructions, wherein the format of the newly generated machine control instructions 
differs from that of the original machine control instructions (column 5, lines 12-23) since in a multi- 
architecture environment, the implementation of subprogram or routine calls across domains involves 
different calling conventions in different architectures and translating or "jacketing" calls enables and 
facilitates cross-domain code execution with efficiency and essential transparency in the multi- 
architecture system (column 2, lines 61-68). 
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30. It would have been obvious to one of ordinary skill in the art at the time the invention was made 
to include the final step of translating or compiling the machine control instructions into another format as 
taught in Brender to the code generating system as taught in Marmelstein since the translating of code to 
operate on different domains enables and facilitates cross-domain code execution with efficiency and 
essential transparency in a multi-architecture system (column 2, lines 61-68). This ability to translate 
code to operate on different architectures would add more flexibility to the system as taught in 
Marmelstein. 

3 1 . Claims 12 and 13 are rejected under 35 U.S.C. 103(a) as being unpatentable over Marmelstein 
as applied to Claim 1 above, and further in view of Lithicum et al (U.S. Patent Number 6,714,213), herein 
referred to as Lithicum. 

32. As to Claims 12 and 13, Marmelstein teaches the user inputs include the manipulation in 
physical space of virtual representations of the objects (column 10, lines 12-13 "selection of objects", 
column 18, lines 31-33, "position the package"), provided by a user interface (Figure 1, elements 10, 20 
and 30). 

33. Marmelstein does not expressly teach this user interface provided by a virtual reality system 
including a force-feedback or haptic interface. 

34. Lithicum teaches the virtual reality system including a force-feedback or haptic interface such 
that when the user moves an object that is proximately close to another object, haptic feedback forces 
provide resistance against the user's attempted manipulation of the movable object that would result in a 
contact or collision between objects (column 2, lines 56-64). 

35. It would have been obvious to one of ordinary skill in the art at the time the invention was made 
to modify the user interface as taught in Marmelstein with the virtual reality system as taught in 
Lithicum since a haptic interface will provide resistance when two objects are moved in close proximity 
to each other and not allow the user to place objects too close or on top of one another as taught in 
Lithicum (column 2, lines 56-64). 

36. Claims 9,18,19 and 28 are rejected under 35 U.S.C. 103(a) as being unpatentable over 
Marmelstein as applied to Claims 1 and 21 above, and further in view of Zink et al (U.S. Patent Number 
6,738,964), herein referred to as Zink. 

37. As to Claim 9, Marmelstein teaches a library of objects (column 10, lines 16-18). 

38. Marmelstein does not expressly teach the library of objects including primitive operators for 
mathematical operations. 
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39. Zink teaches a graphical development system that develops applications for digital signal 
processors using a library of development components that the user can choose from (column 1, lines 47- 
49, column 2, lines 31-33, column 4, lines 35-38, 43-47). Zink further teaches that these components are 
self-contained deployable units of primary functionality and primary functionality refers to mathematical 
functions (column 4, line 64-column 5, line 1). 

40. It would have been obvious to one of ordinary skill in the art at the time the invention was made 
to modify the objects in-the library as taught in M armelstein with the objects including primitive 
operators for mathematical operations as taught in Zink if the system as taught in Marmelstein is used to 
develop machine control instructions to run on a digital signal processor as the system taught in Zink 
(column 1, lines 48-50) since a program that runs on a digital signal processor includes these 
mathematical functions in order to properly function in the desired manner. 

41. As to Claims 18, 19 and 28, Marmelstein teaches user inputs provided by provided by a user 
interface (Figure 1, elements 10, 20 and 30) and updating a network of objects (column 33, lines 28-34, 
40-47). 

42. Marmelstein does not expressly teach the user inputs are provided by at least one user over a 
network connection or said step of updating the network of objects includes updating the network of 
objects to reflect changes made by at least one remote user over a network connection. 

43. Zink teaches a graphical development system that includes a graphical user interface that may be 
accessed via a local area network, the internet, or other remote means for receiving user commands and to 
provide feedback or results to the user (column 3, lines 26-31). 

44. It would have been obvious to one of ordinary skill in the art at the time the invention was made 
that the user interface as taught in Marmelstein could be accessed via a network as taught in Zink and 
doing so would provide more flexibility to users by allowing them access the system from a remote 
location to provide user inputs which would include updating the network of objects. 



Response to Arguments 

45. Applicant's arguments filed on 1/21/05 regarding claims 1-28 have been considered but they are 
not persuasive. 

46. As to the paragraphs regarding the claim interpretations of claims 4 and 17, the response simply 
recites the same claim language without giving an adequate description or proper interpretation of the 
claims. 
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47. Applicant argues: (a) "Marmelstein does not provide any description of a correlating feature to 
the network of objects recited in Claim 1 (page 9, paragraph 3) and (b) "...in the present invention, the 
updating occurs within the network of objects and the connections in the network, as recited in Claim 1 
of the present application, and not merely within a database of objects as taught in Marmelstein" (page 9, 
paragraph 4-page 10, paragraph 1). 

48. As to (a), Marmelstein teaches connecting the selected object to a network of objects consisting 
of those objects previously selected and connected by the user, including identifying the inputs and 
outputs of the selected object and connecting these inputs and outputs to the inputs and outputs of the 
other objects in the network (column 17, lines 55-58, column 19, lines 24-32 and Figure 5) wherein the 
packages are selected by the user and connected via transitions. These packages and transitions make up a 
network of objects wherein the inputs and outputs between objects are defined by the transitions. 

49. As to (b), Marmelstein teaches updating the network of objects and the connections in the 
network to accurately reflect any changes made to the generated machine control instructions or to the 
network of objects (column 33, lines 28-34, 40-47) wherein it is stated: ".. .event handler is used to 
create, select, edit or delete graphic symbols representing states, events, slots and transitions, wherein 
states represent actions or sequences of actions including procedure calls, function calls, code blocks., .". 
Therefore, there is updating of the objects and connections that make up the network. 

50. Applicant argues: (c)". . .Marmelstein discloses the selecting of objects from the database list at 
the start of operation. This has no relation to reading in a sequence of machine control instructions..." 
(page 10, last paragraph) and (d) "While Marmelstein does select objects with which to generate code, it 
does not first read in a model or template code to match with later selected objects" (page 11, first 
paragraph). 

51. As to (c) the cited reference in Marmelstein shows how the user selects an icon or "object" of 
code which then begins the process to obtain the coordinates of the mouse click to generate a pointer to 
the database which holds the objects currently displayed by the editor. This mouse click generates a 
sequence of machine control instructions to obtain this pointer and find the object in the database. As to 
(d), it is unclear how it is interpreted from the claim language that a "model" or "template code" is first 
read in to match with objects selected later. 

52. In response to applicant's arguments against the references individually (page 12, second 
paragraph), one cannot show nonobviousness by attacking references individually where the rejections 
are based on combinations of references. See Inxe Keller, 642 F.2d 413, 208 USPQ 871 (CCPA 1981); 
In re Merck & Co., 800 F.2d 1091, 231 USPQ 375 (Fed. Cir. 1986). 
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53. As to the paragraph (page 12, last paragraph) inviting the Examiner to provide an affidavit 
pursuant to 37 C.F.R 1 . 104 (d)(2), the Examiner has not taken official notice for any claim rejection, 
therefore, it is unclear as to why this paragraph was included in the Response to the Office Action. 

Conclusion 

54. THIS ACTION IS MADE FINAL. Applicant is reminded of the extension of time policy as set 
forth in 37 CFR 1.136(a). 

A shortened statutory period for reply to this final action is set to expire THREE MONTHS from 
the mailing date of this action. In the event a first reply is filed within TWO MONTHS of the mailing 
date of this final action and the advisory action is not mailed until after the end of the THREE-MONTH 
shortened statutory period, then the shortened statutory period will expire on the date the advisory action 
is mailed, and any extension fee pursuant to 37 CFR 1.136(a) will be calculated from the mailing date of 
the advisory action. In no event, however, will the statutory period for reply expire later than SIX 
MONTHS from the mailing date of this final action. 

55. Any inquiry concerning this communication or earlier communications from the examiner should 
be directed to Mary C Hogan whose telephone number is 571-272-3712. The examiner can normally be 
reached on 7:30AM-5PM Monday-Friday. If attempts to reach the examiner by telephone are 
unsuccessful, the examiner's supervisor, Kevin Teska can be reached on 571-272-3716. The fax phone 
number for the organization where this application or proceeding is assigned is 703-872-9306. 
Information regarding the status of an application may be obtained from the Patent Application 
Information Retrieval (PAIR) system. Status information for published applications may be obtained 
from either Private PAIR or Public PAIR. Status information for unpublished applications is available 
through Private PAIR only. For more information about the PAIR system, see http://pair- 
direct.uspto.gov. Should you have questions on access to the Private PAIR system, contact the Electronic 
Business Center (EBC) at 866-217-9197 (toll-free). 



Mary C Hogan 
Examiner 
Art Unit 2 123 




